Part Number Hot Search : 
C74LV ULCE18 IRF82 ERN1321 ADT6402 X3480BC LL103B A1S109
Product Description
Full Text Search
 

To Download AD1940 Datasheet File

  If you can't view the Datasheet, Please click here to try to view without PDF Reader .  
 
 


  Datasheet File OCR Text:
 SigmaDSPTM Multichannel 28-Bit Audio Processor AD1940
FEATURES
16-channel digital audio processor Accepts sample rates up to 192 kHz 28-bit x 28-bit multiplier with full 56-bit accumulator Fully-programmable program RAM for custom program download Parameter RAM allows complete control of 1,024 parameters Control port features safeload for transparent parameter updates and complete mode and memory transfer control Target/slew RAM for click-free volume control and dynamic parameter updates Double precision mode for full 56-bit processing PLL for generating MCLK from 64 x fS, 256 x fS, 384 x fS, or 512 x fS clocks Hardware-accelerated DSP core 21 kB (6,144 words) data memory for up to 128 ms of audio delay at fs = 48 kHz Flexible serial data port with I2S compatible, left-justified, and right-justified serial port modes 8- and 16-channel TDM input/output modes On-chip voltage regulator for compatibility with 3.3 V and 5 V systems Programmable low power mode Fast start-up and boot time from power on or reset 48-lead LQFP plastic package
APPLICATIONS
Automotive sound systems Digital televisions Home theater systems (Dolby Digital/DTS postprocessor) Multichannel audio systems Mini-component stereos Multimedia audio Digital speaker crossover Musical instruments In-seat sound systems (aircrafts/motor coaches)
FUNCTIONAL BLOCK DIAGRAM
4
AD1940
VOLTAGE REGULATOR 2 SERIAL DATA/ TDM INPUTS 28 x 28 DSP CORE 2 2 DATA FORMAT: 5.23 (SINGLE PRECISION) 10.46 (DOUBLE PRECISION) 4 SERIAL CONTROL INTERFACE SERIAL DATA/ TDM OUTPUTS
MASTER CLOCK INPUT
PLL
RAM
ROM
Figure 1.
GENERAL DESCRIPTION
The AD1940 is a complete 28-bit, single-chip, multichannel audio DSP for equalization, multiband dynamics processing, delay compensation, speaker compensation, and image enhancement. These algorithms can be used to compensate for the real-world limitations of speakers, amplifiers, and listening environments, resulting in a dramatic improvement of perceived audio quality. The signal processing used in the AD1940 is comparable to that found in high end studio equipment. Most of the processing is done in full, 56-bit double-precision mode, resulting in very good low level signal performance and the absence of limit cycles or idle tones. The dynamics processor uses a sophisticated, multiple-breakpoint algorithm often found in high end broadcast compressors. The AD1940 is a fully-programmable DSP. Easy to use software allows the user to graphically configure a custom signal processing flow using blocks such as biquad filters, dynamics processors, and surround sound processors. An extensive control port allows click-free parameter updates, along with readback capability from any point in the algorithm flow. The AD1940's digital input and output ports allow a glueless connection to ADCs and DACs by multiple, 2-channel serial data streams or TDM data streams. When in TDM mode, the AD1940 can input 8 or 16 channels of serial data, and can output either 8 or 16 channels of serial data. The input and output port configurations can be individually set. The AD1940 is controlled via a 4-wire SPI port.
Rev. 0
Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties that may result from its use. Specifications subject to change without notice. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. Trademarks and registered trademarks are the property of their respective owners.
One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A. Tel: 781.329.4700 www.analog.com Fax: 781.326.8703 (c) 2004 Analog Devices, Inc. All rights reserved.
04607-0-001
SPI I/O
AD1940 TABLE OF CONTENTS
Specifications..................................................................................... 3 Digital I/O ..................................................................................... 3 Power.............................................................................................. 3 Temperature Range ...................................................................... 3 Digital Timing............................................................................... 4 PLL ................................................................................................. 4 Regulator........................................................................................ 4 Absolute Maximum Ratings............................................................ 5 ESD Caution.................................................................................. 5 Digital Timing Diagrams................................................................. 6 Pin Configuration and Function Descriptions............................. 8 Features ............................................................................................ 10 Pin Functions .............................................................................. 11 Signal Processing ............................................................................ 13 Overview...................................................................................... 13 Numeric Formats........................................................................ 13 Programming .............................................................................. 13 Control Port..................................................................................... 14 Overview...................................................................................... 14 RAMs and Registers....................................................................... 16 Control Port Addressing............................................................ 16 Parameter RAM Contents......................................................... 16 Recommended Program/Parameter Loading Procedures.... 17 Target/Slew RAM ....................................................................... 17 Safeload Registers....................................................................... 19 Data Capture Registers .............................................................. 20 DSP Core Control Register ....................................................... 20 RAM Configuration Register ................................................... 21 Control Port Read/Write Data Formats .................................. 22 Serial Data Input/Output Ports .................................................... 24 Serial Output Control Registers ............................................... 26 Serial Input Control Register .................................................... 26 Initialization .................................................................................... 29 Power-Up Sequence ................................................................... 29 Setting Master Clock/PLL Mode.............................................. 29 Voltage Regulator ....................................................................... 29 Outline Dimensions ....................................................................... 30 Ordering Guide .......................................................................... 30
REVISION HISTORY
7/04--Revision 0: Initial Version
Rev. 0 | Page 2 of 32
AD1940 SPECIFICATIONS
Test conditions, unless otherwise noted. Table 1.
Parameter Supply Voltage (VDD) PLL Voltage (PLL_VDD) Output Voltage (ODVDD) INVDD Voltage Ambient Temperature Master Clock Input Load Capacitance Load Current Input Voltage, HI Input Voltage, LO Conditions 2.5 V 2.5 V 5.0 V 5.0 V 25C 3.072 MHz, 64 x fs mode 50 pF 1 mA 2.4 V 0.8 V
DIGITAL I/O
Table 2. Digital I/O1
Parameter Input Voltage, HI (VIH) Input Voltage, LO (VIL) Input Leakage (IIH) Input Leakage (IIL) High Level Output Voltage (VOH) ODVDD = 4.5 V, IOH = 1 mA High Level Output Voltage (VOH) ODVDD = 3.0 V, IOH = 1 mA Low Level Output Voltage (VOL) ODVDD = 4.5 V, IOL = 1 mA Low Level Output Voltage (VOL) ODVDD = 3.0 V, IOL = 1 mA Input Capacitance
All measurements across -40C to 125C (case) and across VDD = 2.25 V to 2.75 V.
Min 2.1
Max 0.8 10 10
3.9 2.6 0.4 0.3 5
Unit V V A A V V V V pF
1
POWER
Table 3.
Parameter Supplies Voltage Digital Current PLL Current Digital Current, Reset PLL Current, Reset Dissipation Operation, all supplies Reset, all supplies Min 2.25 Typ 2.5 92 3.5 4.53 3 238.8 10.8 Max1 2.75 1552 8 133 8.5 Unit V mA mA mA mA mW mW
Maximum specifications are measured across -40C to 125C (case) and across VDD = 2.25 V to 2.75 V. Measurement running a typical large program that writes to all 16 outputs with 0 dB digital sine waves applied to all eight inputs. Your program may differ. 3 The digital reset current is specified for the given test conditions. This current scales with the input MCLK rate, so higher input clocks draw more current while in reset.
1 2
TEMPERATURE RANGE
Table 4.
Parameter Functionality Guaranteed Min -40 -40 Typ Max +105 +125 Unit C Ambient C Case
Rev. 0 | Page 3 of 32
AD1940
DIGITAL TIMING
Table 5 Digital Timing1
Parameter tMP MCLK Period tMP MCLK Period tMP MCLK Period tMP MCLK Period tMP MCLK Period tMDC MCLK Duty Cycle tBIL BCLK_IN LO Pulse Width tBIH BCLK_IN HI Pulse Width tLIS LRCLK_IN Setup tLIH LRCLK_IN Hold tSIS SDATA_INx Setup tSIH SDATA_INx Hold tLOS LRCLK_OUTx Setup tLOH LRCLK_OUTx Hold BCLK_OUTx Falling to tTS LRCLK_OUTx Timing Skew tSODS SDATA_OUTx Delay tSODM SDATA_OUTx Delay tCCPL CCLK Pulse Width LO tCCPH CCLK Pulse Width HI tCLS CLATCH Setup tCLH CLATCH Hold tCLPH CLATCH Pulse Width HI tCDS CDATA Setup tCDH CDATA Hold tCOD COUT Delay tRLPW RESETB LO Pulse Width Comments 512 fS mode 384 fS mode 256 fS mode 64 fS mode Bypass mode Bypass mode Min 36 48 73 291 12 40 4 2 12 0 3 2 2 2 Max 244 366 488 1953 60 Unit ns ns ns ns ns % ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns
To BCLK_IN rising From BCLK_IN rising To BCLK_IN rising From BCLK_IN rising Slave mode Slave mode
2 Slave mode, from BCLK_OUTx falling Master mode, from BCLK_OUTx falling 1 x INTMCLK (14)2 1 x INTMCLK (14)2 0 2 x INTMCLK + 4 (32)2 2 x INTMCLK (28)2 0 2 x INTMCLK + 2 (30)2 4 x INTMCLK +18 (74)2 10 17 17
To CCLK rising From CCLK rising To CCLK rising From CCLK rising From CCLK rising
All timing specifications are given for the default (I2S) states of the serial input control port and the serial output control ports. See Table 32. These specifications are based on the internal master clock period in a specific application. In normal operation, the master clock runs at 1,536 x fs, so the internal master clock at fs = 48 kHz has a 14 ns period. The values in parentheses are the timing values for fs = 48 kHz.
2
1
PLL
Table 6.
Parameter Lock Time Min Typ 3 Max 20 Unit ms
REGULATOR
Table 7.
Parameter VSENSE Output Voltage Min 2.25 Typ 2.5 Max 2.68 Unit V
Rev. 0 | Page 4 of 32
AD1940 ABSOLUTE MAXIMUM RATINGS
Table 8.
Parameter VDD to DGND PLL_ VDD to PGND OD VDD to DGND INVDD to DGND Digital Inputs Maximum Junction Temperature Storage Temperature Range Soldering (10 sec) Min -0.3 -0.3 -0.3 ODVDD DGND - 0.3 -65 Max +3.0 +3.0 +6.0 +6.0 INVDD + 0.3 135 +150 300 Unit V V V V V C C C
Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Table 9. Package Characteristics
Parameter JA Thermal Resistance (Junction-to-Ambient) JC Thermal Resistance (Junction-to-Case) Min Typ 72 19.5 Max Unit C/W C/W
ESD CAUTION
ESD (electrostatic discharge) sensitive device. Electrostatic charges as high as 4000 V readily accumulate on the human body and test equipment and can discharge without detection. Although this product features proprietary ESD protection circuitry, permanent damage may occur on devices subjected to high energy electrostatic discharges. Therefore, proper ESD precautions are recommended to avoid performance degradation or loss of functionality.
Rev. 0 | Page 5 of 32
AD1940 DIGITAL TIMING DIAGRAMS
tBIH
BCLK_IN
tLIH
tBIL tLIS
LRCLK_IN
tSIS
SDATA_INX LEFT-JUSTIFIED MODE MSB MSB-1
tSIH tSIS
MSB
SDATA_INX I2S-JUSTIFIED MODE
tSIH tSIS
MSB
SDATA_INX RIGHT-JUSTIFIED MODE 8-BIT CLOCKS (24-BIT DATA) 12-BIT CLOCKS (20-BIT DATA) 14-BIT CLOCKS (18-BIT DATA) 16-BIT CLOCKS (16-BIT DATA)
tSIS
LSB
tSIH
tSIH
Figure 2. Serial Input Port Timing
tBIH
BCLK_OUTX
tLCH
tTS
tBIL tLOS
LRCLK_OUTX
SDATA_OUTX LEFT-JUSTIFIED MODE
tSDDS tSDDM
MSB MSB-1
SDATA_OUTX I2S-JUSTIFIED MODE
tSDDS tSDDM
MSB
SDATA_OUTX RIGHT-JUSTIFIED MODE 8-BIT CLOCKS (24-BIT DATA) 12-BIT CLOCKS (20-BIT DATA) 14-BIT CLOCKS (18-BIT DATA) 16-BIT CLOCKS (16-BIT DATA)
tSDDS tSDDM
MSB LSB
Figure 3. Serial Output Port Timing
Rev. 0 | Page 6 of 32
04607-0-014
04607-0-013
AD1940
tCLS tCCPL
CLATCH CCLK CDATA
tCLH tCLPH tCCPH
tCDH tCDS
COUT
tCOD
Figure 4. SPI Port Timing
tMP
MCLK
RESETB
tRLPW
Figure 5. Master Clock and Reset Timing
Rev. 0 | Page 7 of 32
04607-0-016
04607-0-015
AD1940 PIN CONFIGURATION AND FUNCTION DESCRIPTIONS
SDATA_OUT4 SDATA_OUT6 SDATA_OUT5 SDATA_OUT7 VSUPPLY VSENSE VDRIVE ODVDD
INVDD
VREF
GND
48 47 46 45 44 43 42 41 40 39 38 37
VDD 1 MCLK 2 RESERVED 3 PLL_CTRL0 4 PLL_CTRL1 5 PLL_CTRL2 6 PLL_GND 7 PLL_VDD 8 NC
9
VDD
36 GND 35 BCLK_OUT1 34 LRCLK_OUT1 33 ODVDD 32 SDATA_OUT3 31 SDATA_OUT2 30 SDATA_OUT1 29 SDATA_OUT0 28 ODVDD 27 BCLK_OUT0 26 LRCLK_OUT0 25 VDD
PIN 1 INDICATOR
AD1940
TOP VIEW (Not to Scale)
LRCLK_IN 10 BCLK_IN 11 GND 12
13 14 15 16 17 18 19 20 21 22 23 24
CDATA
CLATCH
SDATA_IN1
SDATA_IN0
SDATA_IN2
SDATA_IN3
ADR_SEL
RESETB
COUT
CCLK
GND
VDD
NC = NO CONNECT
Figure 6. 48-Lead LQFP Pin Configuration
Table 10. Pin Function Descriptions
Pin No. 1, 25, 37 2 3 4 5 6 7 8 9 10 11 12, 24, 36, 48 13 14 15 16 17 18 19 20 21 22 23 26 27 28, 33, 40 29 30 I/O IN IN IN IN Mnemonic VDD MCLK RESERVED PLL_CTRL0 PLL_CTRL1 PLL_CTRL2 PLL_GND PLL_VDD NC LRCLK_IN BCLK_IN GND VDD SDATA_IN0 SDATA_IN1 SDATA_IN2/TDM_IN1 SDATA_IN3/TDM_IN0 ADR_SEL COUT CCLK CLATCH CDATA RESETB LRCLK_OUT0 BCLK_OUT0 ODVDD SDATA_OUT0/TDM_O0 SDATA_OUT1 Description Core Power. Master Clock Input. This pin should be connected to ground. PLL Control 0. PLL Control 1. PLL Control 2. PLL Ground. PLL Power. No Connect. Left/Right Clock for Serial or TDM Data Inputs. Bit Clock for Serial or TDM Data Inputs. Digital Ground. Core Power. Serial Data Input 0. Serial Data Input 1. Serial Data Input 2/TDM Input 1. Serial Data Input 3/TDM Input 0. Control Port Address Select. SPI Data Output. SPI Clock. SPI Data Latch. SPI Data Input. Reset the AD1940 Left/Right Clock Output 0. Bit Clock Output 0. Power Connection for Output Pins. Serial Data Output 0/TDM (16- or 8-Channel) Output 0. Serial Data Output 1.
Rev. 0 | Page 8 of 32
IN IN
IN IN IN IN IN OUT IN IN IN IN IN/OUT IN/OUT OUT OUT
04607-0-002
AD1940
Pin No. 31 32 34 35 38 39 41 42 43 44 45 46 47 I/O OUT OUT IN/OUT IN/OUT OUT OUT OUT OUT IN IN OUT OUT Mnemonic SDATA_OUT2 SDATA_OUT3 LRCLK_OUT1 BCLK_OUT1 SDATA_OUT4/TDM_O1 SDATA_OUT5 SDATA_OUT6 SDATA_OUT7/DCSOUT INVDD VSUPPLY VSENSE VDRIVE VREF Description Serial Data Output 2. Serial Data Output 3. Left/Right Clock Output 1. Bit Clock Output 1. Serial Data Output 4/TDM (8-Channel) Output 1. Serial Data Output 5. Serial Data Output 6. Serial Data Output 7/Data Capture Output. Input Voltage Reference. Voltage Level Input to Regulator. Usually 3.3 V or 5 V. Digital Power Level. Should be tied to VDD. Drive for External PNP Transistor. Reference Level for Voltage Regulator.
Rev. 0 | Page 9 of 32
AD1940 FEATURES
The core of the AD1940 is a 28-bit DSP (56-bit with double precision) optimized for audio processing. The AD1940 contains a program RAM that is initialized from an internal program ROM on power-up. The program RAM can be loaded with a custom program after power-up. Signal processing parameters are stored in a 1024-location parameter RAM, which is initialized on power-up by an internal bootROM. New values are written to the parameter RAM using the control port. The values stored in the parameter RAM control individual signal processing blocks, such as IIR equalization filters, dynamics processors, audio delays, and mixer levels. A safeload feature allows parameters to be transparently updated without causing clicks on the output signals. The target/slew RAM contains 64 locations and can be used as channel volume controls or for other parameter updates. These RAM locations take a target value for a given parameter and ramp the current parameter value to the new value using a specified time constant and one of a selection of linear or logarithmic curves. The AD1940 has a sophisticated control port that supports complete read/write capability of all memory locations. Five control registers (core, RAM configuration, Serial Output 0 to 7, Serial Output 8 to 15, and serial input) are provided to offer complete control of the chip's configuration and serial modes. Handshaking is included for ease of memory uploads/downloads.
2 DATA MEMORY 6k x 28 TARGET/SLEW RAM 64 x 28 28 x 28 DSP CORE SERIAL DATA/ TDM OUTPUT GROUP 2
The AD1940 contains eight independent data capture circuits that can be programmed to tap the signal flow of the processor at any point in the DSP algorithm flow. Six of these captured signals can be accessed by reading from the data capture registers through the control port. The remaining two data capture registers can be used to send any internal captured signal to a stereo digital output signal on Pin SDATA_OUT7 for driving external DACs or digital analyzers. The AD1940 has very flexible serial data input/output ports that allows for glueless interconnection to a variety of ADCs, DACs, general-purpose DSPs, S/PDIF receivers, and sample rate converters. The AD1940 can be configured in I2S, left-justified, right-justified, or TDM serial port compatible modes. It can support 16, 20, and 24 bits in all modes. The AD1940 accepts serial audio data in MSB first and twos complement format. The AD1940 operates from a single 2.5 V power supply. It is fabricated on a single monolithic integrated circuit and is housed in a 48-lead LQFP package for operation over the -40C to +105C temperature range.
SERIAL DATA/TDM INPUT GROUP PLL MODE SELECT MASTER CLOCK INPUT SPI I/O GROUP RESETB
2
DATA FORMAT: 5.23 (SINGLE PRECISION) 10.46 (DOUBLE PRECISION) 2 MCLK PLL
BOOT ROM
BOOT ROM
CONTROL REGISITER 4 SERIAL CONTROL PORT TRAP REG. SAFELOAD REGISTER
PROGRAM RAM 1536 x 40
PARAMETER RAM 1024 x 28
COEFFICIENT ROM 512 x 28
04607-0-003
MEMORY CONTROLLERS
VOLTAGE REGULATOR
4
REGULATOR GROUP
Figure 7. Block Diagram
Rev. 0 | Page 10 of 32
AD1940
PIN FUNCTIONS
Table 10 shows the AD1940's pin numbers, names, and functions. Input pins have a logic threshold compatible with TTL input levels and may be used in systems with 3.3 V or 5 V logic. SDATA_IN0 SDATA_IN1 SDATA_IN2/TDM_IN1 SDATA_IN3/TDM_IN0 Serial Data/TDM Inputs. The serial format is selected by writing to Bits 2:0 of the serial input port control register. SDATA_IN2 and SDATA_IN3 are dual-function pins that can be set to a variety of standard 2-channel formats or to TDM mode. Two of these four pins (SDATA_IN2 and SDATA_IN3) can be used as TDM inputs in either dual-wire 8-channel mode or single-wire 16-channel mode (TDM_O0 only). In dual-wire 8-channel mode, Channels 0-7 will be input on SDATA_IN3 and Channels 8-15 on SDATA_IN2. In single-wire 16-channel mode, Channels 0-15 will be input on SDATA_IN2. See the Serial Data Input/Output Ports section for further explanation. LRCLK_IN BCLK_IN Left/Right and Bit Clocks for Timing the Input Data. These input clocks are associated with the SDATA_IN0-3 signals. The input port is always in a slave configuration. These pins also function as frame sync and bit clock for the input TDM stream. SDATA_OUT0/TDM_O0 SDATA_OUT1 SDATA_OUT2, SDATA_OUT3 SDATA_OUT4/TDM_O1 SDATA_OUT5 SDATA_OUT6 SDATA_OUT7/DCSOUT Serial Data/TDM/Data Capture Outputs. These pins are used for serial digital outputs. For non-TDM systems, these eight pins can output 16 channels of digital audio, using a variety of standard two-channel formats. They are grouped into two groups of four pins (0-3 and 4-7); each group can be independently set to any of the available serial modes, allowing the AD1940 to simultaneously communicate with two external devices with different serial formats. Two of these eight pins (SDATA_OUT0 and SDATA_OUT4) can be used as TDM outputs in either dual-wire 8-channel mode or single-wire 16-channel mode (TDM_OUT0 only). In dual-wire 8-channel mode, Channels 0-7 will be output on SDATA_OUT0 and Channels 8-15 on SDATA_OUT4. See the Serial Data Input/Output Ports section for further explanation. SDATA_OUT7 can also be used as a data capture output, as described in the Data Capture Registers section. LRCLK_OUT0 BCLK_OUT0 Output Clocks. This clock pair is used for outputs SDATA_OUT0-3. In slave mode, these clocks are inputs to the AD1940. On power-up, these pins are set to slave mode to avoid conflicts with external master-mode devices. LRCLK_OUT1 BCLK_OUT1 Output Clocks. This clock pair is used for outputs SDATA_OUT4-7. In slave mode, these clocks are inputs to the AD1940. On power-up, these pins are set to slave mode to avoid conflicts with external master-mode devices. MCLK Master Clock Input. The AD1940 uses a PLL to generate the appropriate internal clock for the DSP core. An in-depth description of using the PLL is found in the Setting Master Clock/PLL Mode section. PLL_CTRL0 PLL_CTRL1 PLL_CTRL2 PLL Mode Control Pins. The functionality of these pins is described in the Setting Master Clock/PLL Mode section. CDATA Serial Data Input for the SPI Control Port. COUT Serial Data Output for the SPI Port. This is used for reading back registers and memory locations. It is three-stated when an SPI read is not active. CCLK SPI Bit Clock. This clock may either run continuously or be gated off in between SPI transactions. CLATCH SPI Latch Signal. This must go low at the beginning of an SPI transaction and high at the end of a transaction. Each SPI transaction may take a different number of CCLKs to complete, depending on the address and read/write bit that are sent at the beginning of the SPI transaction. ADR_SEL Address Select. This pin selects the address for the AD1940's communication with the control port. This allows two AD1940s to be used with a single CLATCH signal.
Rev. 0 | Page 11 of 32
AD1940
RESETB Active-Low Reset Signal. After RESETB goes high, the AD1940 goes through an initialization sequence where the program and parameter RAMs are initialized with the contents of the onboard boot ROMs. All registers are set to 0, and the data RAMs are also set to 0. The initialization is complete after 8,192 internal MCLK cycles (referenced to the rising edge of RESETB), which corresponds to 1,366 external MCLK cycles if the part is in 256 x fS mode. New values should not be written to the control port until the initialization is complete. VREF Voltage Reference for Regulator. This pin is driven by an internal 1.15 V reference voltage. VDRIVE Drive for External Transistor. The base of the voltage regulator's external PNP transistor is driven from this pin. VSENSE Digital power level. The voltage level on the VDD pins is sensed on VSENSE. VSENSE should be tied to VDD. VSUPPLY Main Supply Voltage Level. This pin is tied to the board's main voltage supply. This is usually 3.3 V or 5 V. VDD (4) Digital VDD for Core. 2.5 V nominal. GND (4) Digital Ground. PLL_VDD Supply for AD1940 PLL. 2.5 V nominal. PLL_GND PLL Ground. ODVDD (3) VDD for All Digital Outputs. The high levels of the digital output signals are set on this pin. The voltage can range from 2.5 V to 5.0 V. INVDD Peak Input Voltage Level. The highest voltage level that the input pins will see should be connected to INVDD. This is to protect the chip inputs from voltage overstress. The voltage on this pin must always be at or above the level of ODVDD.
Rev. 0 | Page 12 of 32
AD1940 SIGNAL PROCESSING
OVERVIEW
The AD1940 is designed to provide all signal processing functions commonly used in stereo or multichannel playback systems. The signal processing flow is set by using the ADIsupplied software, which allows graphical entry and real-time control of all signal processing functions. Many of the signal processing functions are coded using full, 56-bit double-precision arithmetic. The input and output word lengths are 24 bits. Four extra headroom bits are used in the processor to allow internal gains up to 24 dB without clipping. Additional gains can be achieved by initially scaling down the input signal in the signal flow. The signal processing blocks can be arranged in a custom program that can be loaded to the AD1940's RAM. The available signal processing blocks are explained in the following sections.
DATA IN 4-BIT SIGN EXTENSION SIGNAL PROCESSING (5.23 FORMAT) 1.23 5.23 5.23 DIGITAL CLIPPER 1.23 SERIAL PORT
04607-0-005
Figure 8. Numeric Precision and Clipping Structure
PROGRAMMING
On power-up, the AD1940's default program passes the unprocessed input signals to the outputs but the outputs come up muted by default (see Power-Up Sequence section). There are 1,536 instruction cycles per audio sample, resulting in an internal clock rate of 73.728 MHz (for fs = 48 kHz). This DSP runs in a stream-oriented manner, meaning all 1,536 instructions are executed each sample period. The AD1940 may also be set up to accept double or quad-speed inputs by reducing the number of instructions/sample, which can be set in the core control register. The part can be programmed easily using graphical tools provided by Analog Devices. No knowledge of writing DSP code is needed to program this part. The user can simply connect graphical blocks such as biquad filters, dynamics processors, mixers, and delays in a signal flow schematic, compile the design, and load the program and parameter files into the AD1940's Program RAM through the control port. Signal processing blocks available in the provided libraries include * * * * * * * * * * * Single- and double-precision biquad filters Mono and multichannel dynamics processors Mixers and splitters Tone and noise generators First-order filters Fixed and variable gain RMS look-up tables Loudness Delay Stereo enhancement (Phat StereoTM) Interpolators and Decimators
NUMERIC FORMATS
It is common in DSP systems to use a standardized method of specifying numeric formats. Fractional number systems are specified by an A.B format, where A is the number of bits to the left of the decimal point and B is the number of bits to the right of the decimal point. The AD1940 uses the same numeric format for both the coefficient values (stored in the parameter RAM) and the signal data values. The format is as follows: Numerical Format: 5.23 Range: -16.0 to (+16.0 - 1 LSB) Examples: 1000000000000000000000000000 = -16.0 1110000000000000000000000000 = -4.0 1111100000000000000000000000 = -1.0 1111111000000000000000000000 = -0.25 1111111111111111111111111111 = (1 LSB below 0.0) 0000000000000000000000000000 = 0.0 0000001000000000000000000000 = 0.25 0000100000000000000000000000 = 1.0 0010000000000000000000000000 = 4.0 0111111111111111111111111111 = (16.0 - 1 LSB). The serial port accepts up to 24 bits on the input and is signextended to the full 28 bits of the core. This allows internal gains of up to 24 dB without encountering internal clipping. A digital clipper circuit is used between the output of the DSP core and the serial output ports (see Figure 8). This clips the top four bits of the signal to produce a 24-bit output with a range of 1.0 (minus 1 LSB) to -1.0.
More blocks are always in development. Analog Devices also provides proprietary and third-party algorithms for applications such as matrix decoding, bass enhancement, and surround virtualizers. Please contact ADI for information about licensing these algorithms.
Rev. 0 | Page 13 of 32
AD1940 CONTROL PORT
OVERVIEW
The AD1940 has many different control options that can be set through an SPI interface. Most signal processing parameters are controlled by writing new values to the parameter RAM using the control port. Other functions, such as mute and input/ output mode control, are programmed by writing to the control registers. The control port is capable of full read/write operation for all of the memories and registers. All addresses may be accessed in both a single-address mode or a burst mode. A control word consists of the chip address, the register/RAM subaddress, and the data to be written. The data can be variable in its byte width. The first byte of a control word (Byte 0) contains the 7-bit chip address plus the R/W bit. The next two bytes (Bytes 1 and 2) together form the subaddress of the memory or register location within the AD1940. This subaddress needs to be two bytes because the memories within the AD1940 are directly addressable, and their sizes exceed the range of single-byte addressing. All subsequent bytes (Bytes 3, 4, etc.) contain the data, such as control port data or program or parameter data. The AD1940 has several mechanisms for updating signal processing parameters in real time without causing pops or clicks. In cases where large blocks of data need to be downloaded, the output of the DSP core can be halted (using Bit 9 of the core control register), new data loaded, and then restarted. This is typically done during the booting sequence at start-up or when loading a new program into RAM. In cases where only a few parameters need to be changed, they can be loaded without halting the program. To avoid unwanted side effects while loading parameters on the fly, the SigmaDSP provides the safeload registers. The safeload registers can be used to buffer a full set of parameters (e.g. the five coefficients of a biquad) and then transfer these parameters into the active program within one audio frame. The safeload mode uses internal logic to prevent contention between the DSP core and the control port. The SPI port uses a 4-wire interface, consisting of CLATCH, CCLK, CDATA, and COUT signals. The CLATCH signal goes low at the beginning of a transaction and high at the end of a transaction. The CCLK signal latches CDATA on a low-to-high transition. COUT data is shifted out of the AD1940 on the falling edge of CCLK and should be clocked into the receiving device, such as a microcontroller, on CCLK's rising edge. The CDATA signal carries the serial input data, and the COUT signal is the serial output data. The COUT signal remains threestated until a read operation is requested. This allows other SPIcompatible peripherals to share the same readback line. All SPI transactions follow the same basic format, shown in Table 11. A timing diagram is shown in Figure 4. All data written should be MSB-first. Table 11. Generic SPI Word Format
Byte 0 chip_adr [6:0], R/W Byte 1 0000, adr[11:8] Byte 2 adr[7:0] Byte 3 data Byte 4, etc. data
Chip Address R/W The first byte of an SPI transaction includes the 7-bit chip address and a R/W bit. The chip address is set by the ADR_SEL pin. This allows two AD1940s to share a CLATCH signal, yet still operate independently. When ADR_SEL is low, the chip address is 0000000; when it is high, the address is 0000001. The LSB of this first byte determines whether the SPI transaction is a read (Logic Level 1) or a write (Logic Level 0). RAM/Register Address The 12-bit RAM/register address word is decoded into a location in one of the memories or registers. Data Bytes The number of data bytes varies according to the register or memory being accessed. In burst write mode, an initial address is given followed by a continuous sequence of data for consecutive memory/register locations. The detailed data format diagram for continuous-mode operation is given in the Control Port Read/Write Data Formats section. A sample timing diagram for a single SPI write operation to the parameter RAM is shown in Figure 9. A sample timing diagram of a single SPI read operation is shown in Figure 10. The COUT pin goes from three-state to driven at the beginning of Byte 3. In this example, Bytes 0 to 2 contain the addresses and R/W bit, and subsequent bytes carry the data. The exact formats for specific types of writes are shown in Table 21 to Table 30.
Rev. 0 | Page 14 of 32
AD1940
CLATCH
CCLK
04607-0-006
CDATA
BYTE 0
BYTE 1
BYTE 2
BYTE 3
Figure 9. Sample of SPI WRITE format (Single-Write Mode)
CLATCH
CCLK
CDATA
BYTE 0
BYTE 1
04607-0-007
COUT
HI-Z
DATA
DATA
DATA
HI-Z
Figure 10. Sample of SPI READ Format (Single-Read Mode)
Rev. 0 | Page 15 of 32
AD1940 RAMS AND REGISTERS
Table 12. Control Port Addresses
SPI Address 0-1023 (0x0000-0x03FF) 1024-2559 (0x0400-0x09FF) 2560-2623 (0x0A00-0x0A3F) 2624-2628 (0x0A40-0x0A44) 2629-2633 (0x0A45-0x0A49) 2634-2639 (0x0A4A-0x0A4F) 2640-2641 (0x0A50-0x0A51) 2642 (0x0A52) 2643 (0x0A53) 2644 (0x0A54) 2645 (0x0A55) 2646 (0x0A56) Register Name Parameter RAM Program RAM Target/Slew RAM Parameter RAM Data Safeload Registers 0-4 Parameter RAM Indirect Address Safeload Registers 0-4 Data Capture Registers 0-5 (Control Port Readback) Data Capture Registers (Digital Output) DSP Core Control Register RAM Configuration Register Serial Output Control Register 1 (Channels 0-7) Serial Output Control Register 2 (Channels 8-15) Serial Input Control Register Read/Write Word Length Write: 4 Bytes, Read: 4 Bytes Write: 5 Bytes, Read: 5 Bytes Write: 5 Bytes, Read: N/A Write: 5 Bytes, Read: N/A Write: 2 Bytes, Read: N/A Write: 2 Bytes, Read: 3 Bytes Write: 2 Bytes, Read: N/A Write: 2 Bytes, Read: 2 Bytes Write: 1 Byte, Read: 1 Byte Write: 2 Bytes, Read: 2 Bytes Write: 2 Bytes, Read: 2 Bytes Write: 1 Byte, Read: 1 Byte
Table 13. RAM Read/Write Modes
Memory Parameter RAM Program RAM Target/Slew RAM Size 1024 x 28 1536 x 40 64 x 34 SPI Address Range 0-1023 (0x0000-0x03FF) 1024-2559 (0x0400-0x09FF) 2560-2623 (0x0A00-0x0A3F) Read Yes Yes No Write Yes Yes Yes (via Safeload) Burst Mode Available? Yes Yes Yes2 Write Modes Direct Write1 Safeload Write Direct Write1 Safeload Write
1 2
DSP core should be shut down first to avoid clicks/pops. The target/slew RAMs need to be written through the safeload registers. Safeload writes may be done in either single-write or burst-mode.
CONTROL PORT ADDRESSING
Table 12 shows the addressing of the AD1940's RAM and register spaces. The address space encompasses a set of registers and three RAMs: one each for holding signal processing parameters, holding the program instructions, and ramping parameter values. The program and parameter RAMs are initialized on power-up from on-board boot ROMs. Table 13 shows the sizes and available writing modes of the parameter, program, and target/slew RAMs.
1.
PARAMETER RAM CONTENTS
The parameter RAM is 28 bits wide and occupies Addresses 0 to 1023. The parameter RAM is initialized to all 0s on power-up. The data format of the parameter RAM is twos complement 5.23. This means that the coefficients may range from +16.0 (minus 1 LSB) to -16.0, with 1.0 represented by the binary word 0000100000000000000000000000. Options for Parameter Updates The parameter RAM can be written and read using one of the two following methods. 2.
Direct Read/Write. This method allows direct access to the program and parameter RAMs. This mode of operation is normally used during a complete new load of the RAMs, using burst-mode addressing. The clear registers bit in the core control register should be set to 0 using this mode to avoid any clicks or pops in the outputs. Note that it is also possible to use this mode during live program execution, but since there is no handshaking between the core and the control port, the parameter RAM will be unavailable to the DSP core during control writes, resulting in clicks and pops in the audio stream. Safeload Writes. Up to five safeload registers can be loaded with address/data intended for the parameter RAM. The data is then transferred to the requested address when the RAM is not busy. This method can be used for dynamic updates while live program material is playing through the AD1940/AD1941. For example, a complete update of one biquad section can occur in one audio frame, while the RAM is not busy. This method is not available for writing to the program RAM or control registers.
The following section discusses these two options in more detail.
Rev. 0 | Page 16 of 32
AD1940
RECOMMENDED PROGRAM/PARAMETER LOADING PROCEDURES
When writing large amounts of data to the program or parameter RAM in direct write mode, the processor core should be disabled to prevent unpleasant noises from appearing at the audio output. The AD1940 contains several mechanisms for disabling the core. If the loaded program does NOT use the target/slew RAM as the main system volume control (for example, the default power-up program) 1. Assert Bit 9 (LOW to assert--default setting) and Bit 6 (HIGH to assert) of the core control register. This zeroes the accumulators, the serial output registers, and the serial input registers. Fill the program RAM using burst mode writes. Fill the parameter RAM using burst mode writes. Assert Bit 7 of the core control register to initiate a datamemory clear sequence. Wait at least 100 s for this sequence to complete. This bit is automatically cleared after the operation is complete. Deassert Bit 9 and Bit 6 of the core control register to allow the core to begin normal operation
TARGET/SLEW RAM
The target/slew RAM is a bank of 64 RAM locations, each of which can each be set to autoramp from one value to a desired final value in one of four modes. Summary The target/slew RAM is used by the DSP when a program is loaded into the program RAM that uses one or more locations in the slew RAM to access internal coefficient data. Typically, these coefficients are used for volume controls or smooth crossfading effects, but may be used to update any value in the parameter RAM. Each of the 64 locations in the slew RAM are linked to corresponding locations in the target RAM. When a new value is written to the target RAM using the control port, the corresponding slew RAM location begins to ramp toward the target. The value is updated once per audio frame (LRCLK period). The target RAM is 34 bits wide. The lower 28 bits contain the target data in 5.23 format for the linear and exponential (constant dB and RC-type) ramp types. For constant time ramping, the lower 28 bits contain 16 bits in 2.14 format and 12 bits to set the current step. The upper six bits are used to determine the type and speed of the ramp envelope in all modes. The format of the data write for linear and exponential formats is shown in Table 14. Table 15 shows the data write format for the constant time ramping. Data can only be written to the target/slew RAM using the safeload registers as described in the Safeload Registers section. A mute slew RAM bit is included in the core control register to simultaneously set all the slew RAM target values to 0. This is useful for implementing a global multichannel mute. When this bit is deasserted, all slew RAM values will return to their original pre-muted states. Table 14. Linear, Constant dB, and RC-type Ramp Data Write
Byte 0 000000, curve_type[1:0] Byte 1 time_const[3:0], data[27:24] Bytes 2-4 data[23:0]
2. 3. 4.
5.
If the loaded program does use the target/slew RAM as the main system volume control: 1. Assert Bit 12 of the core control register. This begins a volume ramp-down, with a time constant determined by the upper bits of the target RAM. Wait for this ramp-down to complete (the user may poll Bit 13 of the core control register, or simply wait for a given amount of time). Assert Bit 9 (LOW to assert) and Bit 6 (HIGH to assert) of the core control register. This zeroes the accumulators, the serial output registers, and the serial input registers. Fill the program RAM using burst-mode writes. Fill the parameter RAM using burst-mode writes. Assert Bit 7 of the core control register to initiate a datamemory clear sequence. Wait at least 100 s for this sequence to complete. This bit is automatically cleared after the operation is complete. Deassert Bit 9 and Bit 6 of the core control register. If the newly loaded program also uses the target/slew RAM, deassert Bit 12 of the core control register to begin a volume ramp-up procedure.
2.
3. 4. 5.
Table 15. Constant Time Ramp Data Write
Byte 0 000000, curve_type[1:0] Byte 1 update_step[0], #_of_steps[2:0], data[15:12] Bytes 2-4 data[11:0], reserved[11:0]
6. 7.
Rev. 0 | Page 17 of 32
AD1940
The four ramping curve types are 1. 2. Linear--Value slews to target using a fixed step size. Constant dB--Value slews to target using the current value to calculate the step size. The resulting curve has a constant rise and decay when measured in dB. RC-type--Value slews to target using the difference between target and current values to calculate the step size, producing a simple RC type curve for rising and falling. Constant Time--Value slews to the target in a fixed number of steps in a linear fashion. The control port mute has no affect on this type. * * Data (16 bits). 2.14 format. Reserved (12 bits). When writing to the RAM, these bits should all be set to 0. Target and Slew RAM Initialization On reset, the target/slew RAM initializes to preset values. The target RAM initializes to a linear ramp type with a time constant of 5 and the data set to 1.0. The slew RAM initializes to a value of 1.0. These defaults give a full-scale (1.0 to 0.0) ramp time of 21.3 ms. Linear Update Math Linear math is the addition or subtraction of a constant value (step). The equation to describe this step size is
3.
4.
Table 16 Target/Slew RAM Ramp Type Settings
Setting 00 01 10 11 Ramp Type Linear Constant dB RC-Type Constant Time
step =
213
10
2x( tconst - 5 )
20
The following sections detail how the control port writes to the target/slew RAM to control the time constant and ramp type parameters. Ramp Types 1-3: Linear, Constant dB, RC-type (34-Bit Write) The target word for the first three ramp types is broken up into three parts. The 34-bit command is written with six leading 0s to extend the data write to five bytes. The parts of the target RAM write are described below. * * Ramp Type (2 bits) Time Constant (4 bits) 0000 = Fastest 1111 = Slowest * Data (28 Bits): 5.23 Format Ramp Type 4--Constant Time (34-Bit Write) The target word for the constant time ramp type is written in five parts, with the 34-bit command again written with six leading zeros to extend the data write to five bytes. The parts of the constant time target RAM write are described below. * * Ramp Type (2 bits). Update Step (1 bit). Set to 1 when new target is loaded to trigger step value update. Value is automatically reset after the step value is updated. * Number of Steps (3 bits). The number of steps that it takes to slew to the target value is set by these three bits, with the number of steps equal to 23-bit setting + 6. 000 = 64 001 = 128 010 = 256 011 = 512 100 = 1024 101 = 2048 110 = 4096 111 = 8196
The result of the equation is normalized to 5.23 data format. This gives a time constant range from 6.75 ms to 213.4 ms. (-60 dB relative to 0 dB full scale). An example of this kind of update is shown in Figure 11. All slew RAM figure examples, except the second constant time plot, show a ramp from -80 dB to 0 dB (full scale). All figures except the constant time plots (Figure 14 and Figure 15) use a time constant of 0x7 (0x0 being the fastest and 0xF being the slowest).
1 0.8 0.6
OUTPUT LEVEL (V)
0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 0 10 20 TIME (ms) 30
04607-0-017
Figure 11. Slew RAM--Linear Update Plot
Constant dB and RC-type (Exponential) Update Math Exponential math is accomplished by shifts and adds with a range from 6.1 ms to 1.27 s (-60 dB relative to 0 dB full scale). When the ramp type is set to 01 (constant dB), each step size is set to the current value in the slew data. When the ramp type bits are set to 10 (RC type), the step sizes are equal to the difference between the values in the target RAM and slew RAM. Figure 12 and Figure 13 show examples of this type of target/slew RAM ramping. A decaying plot of both the constant dB and RC-type ramps would be a mirror image of what is shown in Figure 12.
Rev. 0 | Page 18 of 32
AD1940
1 0.8 0.6
OUTPUT LEVEL (V) OUTPUT LEVEL (V)
1 0.8 0.6 0.4 0.2 0 -0.2 -0.4 -0.6
04607-0-018
0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 0 5 10 15 20 TIME (ms) 25 30
-0.8 -1 0 10 20 TIME (ms) 30
35
Figure 12. Slew RAM--Constant dB Update Plot
1 0.8 0.6
OUTPUT LEVEL (V) OUTPUT LEVEL (V)
Figure 14 Slew RAM--Constant Time Update Plot, Full Scale
1 0.8 0.6 0.4 0.2 0 -0.2 -0.4 -0.6
04607-0-019
0.4 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 0 10 20 TIME (ms) 30
-0.8 -1 0 10 20 TIME (ms) 30
Figure 13. Slew RAM--RC-Type Update Plot
Figure 15 Slew RAM--Constant Time Update Plot, Half Scale
Constant Time Update Math Constant time math is accomplished by adding a step value that is calculated after each new target is loaded. The equation for this step size is Step = (Target Data - Slew Data)/(Number of Steps) Figure 14 shows a plot of the target/slew RAM operating in constant time mode. For this example, 128 steps are used to reach the target value. This type of ramping will take a fixed amount of time for a given number of steps, regardless of the difference in the initial state and the target value. Figure 15 shows a plot of a constant time ramp from -80 dB to -6 dB (half scale) using 128 steps. You can see that the ramp takes the same amount of time as the previous ramp from -80 dB to 0 dB.
SAFELOAD REGISTERS
Many applications require real-time control of signal processing parameters, such as filter coefficients, mixer gains, multichannel virtualizing parameters, or dynamics processing curves. To prevent instability from occurring, all of the parameters of a biquad filter must be updated at the same time. Otherwise, the filter could execute for one or two audio frames with a mix of old and new coefficients. This mix could cause temporary instability, leading to transients that could take a long time to
decay. To eliminate this problem, the AD1940 loads a set of 10 registers in the control port (five for 28-bit parameters, and another five for indirectly addressing the target/slew RAMs) with the desired parameter or target/slew RAM address and data. Five registers are used because a biquad filter uses five coefficients, and it is desirable to be able to do a complete biquad update in one transaction. The safeload registers can be used to update either the parameter RAM or target/slew RAM values. Once these registers are loaded, the appropriate initiate safe transfer bit (there are separate bits for parameter and target/slew loads) in the core control register should be set to initiate the loading into RAM. Program lengths should be limited to 1,531 cycles (1,536 - 5) to ensure that the SigmaDSP is able to perform the safeloads. It can be guaranteed that the safeload will have occurred within one LRCLK period (21 s at fs = 48 kHz) of the initiate safe transfer bit being set. The safeload logic automatically sends only those safeload registers that have been written to since the last safeload operation. For example, if only two parameters are to be sent, only two of the five safeload registers must be written to. When the initiate safe transfer bit (in the core control register) is asserted, only those two registers are sent; the other three registers are not sent to the RAM and can still hold old or invalid data.
Rev. 0 | Page 19 of 32
04607-0-021
04607-0-020
AD1940
Table 17. Data Capture Control Registers (2634-2641)
Register Bits 12:2 1:0 Function 11-Bit Program Counter Address Register Select 00 = Mult_X_input 01 = Mult_Y_input 10 = MAC_output 11 = Accum_fback
concatenation of the 11-bit program count index with the 2-bit register select field. The capture count and register select values that correspond to the desired point to be monitored in the signal processing flow can be found in a file output from the program compiler. The capture registers can be accessed by reading from locations 2634 to 2639 (for control port capture registers). The format for reading and writing to the data capture registers can be seen in Table 27 and Table 28. Table 19. DSP Core Control Register (2642)
Register Bits 15:14 13 12 11 10 9 8 7 6 5 4 3:2 Function Reserved Slew RAM Muted (Read Only) Mute Slew RAM, All Locations Reserved, Set to 0 Use Serial Out LRCLK for Output Latch Clear Internal Registers to All 0s, Active Low Force Multiplier to 0 Inititalize Data Memory with 0s Mute Serial Input Port Initiate Safe Transfer to Target RAM Initiate Safe Transfer to Parameter RAM Input Serial Port to Sequencer Sync 00 = LRCLK 01 = LRCLK/2 10 = LRCLK/4 11 = LRCLK/8 Program Length 00 = 1536 01 = 768 10 = 384 11 = 192
DATA CAPTURE REGISTERS
The AD1940's data capture feature allows the data at any node in the signal processing flow to be sent to one of six control port-readable registers or to a serial output pin. This can be used to monitor and display information about internal signal levels or compressor/limiter activity. The AD1940 contains six independent control port-readable data capture registers, and two digital output capture registers. The digital output registers are output on SDATA_OUT7 when the data capture serial out enable bit (Bit 14) is set in Serial Output Control Register 2. These registers are useful when debugging the signal processing flow. For each of the data capture registers, a capture count and a register select must be set. The capture count is a number between 0 and 1,535 that corresponds to the program step number where the capture will occur. The register select field programs one of four registers in the DSP core that will be transferred to the data capture register when the program counter equals the capture count. The register select field selections are shown in Table 18. Table 18. Data Capture Output Register Select
Setting 00 01 10 11 Register Multiplier X Input (Mult_X_input) Multiplier Y Input (Mult_Y_input) Multiplier-Accumulator Output (MAC_out) Accumulator Feedback (Accum_fback)
1:0
DSP CORE CONTROL REGISTER
The controls in this register set the operation of the AD1940's DSP core. Bits 6 to 9 can be set to initiate a shutdown of the core. The output is muted when this is performed, so it is best to first assert the mute slew RAM bit (if slew RAM locations are used as volume controls in the program) to avoid a click or pop when shutdown is asserted. Slew RAM Muted (Bit 13) This bit is set to 1 when the slew RAM mute operation has been completed. This bit is read-only and is automatically cleared by reading. Mute Slew RAM, All Locations (Bit 12) Setting this bit to 1 initiates a mute of all 64 slew RAM locations. When reset to 0, all RAM locations return to their previous state. This bit is only functional if slew RAM locations are used in the custom program design. Keep in mind that the AD1940's default program does not use any slew RAM volume controls, so this bit has no effect in that case. The mute operation is identical to writing all 0s to the data portion of the target RAM, and therefore the time constant and linear/ exponential curve selection is determined by the bits that have
The capture count and register select bits are set by writing to one of the eight data capture registers at register addresses 2634: Control Port Data Capture Setup Register 0 2635: Control Port Data Capture Setup Register 1 2636: Control Port Data Capture Setup Register 2 2637: Control Port Data Capture Setup Register 3 2638: Control Port Data Capture Setup Register 4 2639: Control Port Data Capture Setup Register 5 2640: Digital Out Data Capture Setup Register 0 2641: Digital Out Data Capture Setup Register 1 The captured data is in 5.19 twos complement data format for all eight register select fields. The four LSBs are truncated from the internal 5.23 data-word. The data that must be written to set up the data capture is a
Rev. 0 | Page 20 of 32
AD1940
been previously written to the high bits of the target RAM. Use Serial Out LRCLK for Output Latch (Bit 10) Normally, data is transferred from the DSP core to the serial output registers at the end of each program cycle. In some cases (e.g., when output sample rate is set to some multiple of input sampling rate), it is desirable to transfer the internal core data multiple times during a single input audio sample period. Setting this bit to 1 allows the output LRCLK signal to control this data transfer rather than the internal end-of-sequence signal. Operation in this mode may require custom assembly-language coding in the ADI graphical tools. Clear Registers to All Zeros (Bit 9) Setting this bit to 0 sets the contents of the accumulators and serial output registers to 0. Like the other register bits, this one powers up to 0. This means the AD1940 powers up in clear mode and will not pass a signal until a 1 is written to this bit. This is intended to prevent noises from inadvertently occurring during the power-up sequence. Force Multiplier to Zero (Bit 8) When this bit is set to 1, the input to the DSP multiplier is set to 0, which results in the multiplier output being 0. This control bit is included for maximum flexibility, and is normally not used. Initialize Data Memory with Zeros (Bit 7) Setting this bit to 1 initializes all data memory locations to 0. This bit is cleared to 0 after the operation is complete. This bit should be asserted after a complete program/parameter download has occurred to ensure click-free operation. Zero Serial Input Port (Bit 6) When this bit is set to 1, the 16 serial input channels are forced to all 0s. Initiate Safe Transfer to Target RAM (Bit 5) Setting this bit to 1 initiates a safeload transfer to the target/slew RAM. This bit is cleared when the operation is completed. There are five safeload register pairs (address/data); only those registers that have been written since the last safeload event are transferred. Address 0 corresponds to the first target RAM location. Initiate Safe Transfer to Parameter RAM (Bit 4) Setting this bit to 1 initiates a safeload transfer to the parameter RAM. This bit is cleared when the operation is completed. There are five safeload registers pairs (address/data); only those registers that have been written since the last safeload event are transferred. Address 0 corresponds to the first parameter RAM location. Input Serial Port to Sequencer Sync (Bits 3:2) Normally, the internal sequencer is synchronized to the incoming audio frame rate by comparing the internal program counter with the edge of the LRCLK input signal. In some cases the AD1940 may be used to decimate an incoming signal by Low Power Mode This setting can also be used to reduce the power consumption of the AD1940. If the program length is set to 768 steps and fs = 48 kHz, instead of 96 kHz, then the power consumption of the part will be cut in approximately half. Correspondingly, when the program length is set to 384 steps with fs = 48 kHz the power consumption will be about 1/4 of what it is in normal operation with 1,536 program steps and fs = 48 kHz. Table 20. RAM Configuration Register (2643)
Register Bits 7:4 3:0 Function Reserved RAM Modulo, 1 LSB corresponds to 512 locations, max = 0b1100 (6 k)
some integer factor. In this case, it is desirable to synchronize the sequencer to a submultiple of the incoming LRCLK rate so more than one audio input sample is available to the program during a single audio output frame. For example, if these bits are set to 01 (LRCLK/2), a 96 kHz input can be used with a 48 kHz output, allowing two consecutive input samples to be processed during a single audio output frame. Operation in this mode may require custom assembly-language coding in the ADI graphical tools. Program Length (Bits 1:0) 96 kHz and 192 kHz modes These bits set the length of the internal program. The default program length is 1,536 instructions for fs = 48 kHz, but the program length can be shortened by factors of 2 to accommodate sample rates higher than 48 kHz. For fs = 96 kHz the program length should be set to 768 (01), and the length should be set at 384 steps (10) for fs = 192 kHz. A program length of 192 steps is available, but will not be commonly used.
RAM CONFIGURATION REGISTER
The AD1940 uses a modulo RAM addressing scheme to allow filters and other blocks to be coded easily without requiring filter data to be explicitly moved during the filtering operation. This is accomplished by adding the contents of an address offset counter to the actual base address supplied in the AD1940's core. This address offset counter is incremented automatically at the audio frame rate. This method works well for most audio applications that involve filtering. In some cases, however, it is desirable to have direct access to the RAM, bypassing the autoincrementing address offset counter. For this reason, the data memory in the AD1940 can be divided into modulo and nonmodulo portions by programming the RAM configuration register (Table 20). The address range from 0 to 512 x (RAM configuration register contents) is treated as modulo memory with autoincrementing address offset registers. The maximum setting of this register is the full size of the RAM, or 6,144 (6 k) data words. Note that
Rev. 0 | Page 21 of 32
AD1940
addresses in this range automatically wrap around the modulo boundary as set by the register. This feature is not normally used with ADI-supplied blocks. For normal operation, this register may be left in its default state, which sets up the entire RAM to use the autoincrement feature. This feature is included for maximum programming flexibility and may be used in the case of specialized software development. zero-extended data fields are appended to a 3-byte field consisting of a 7-bit chip address, a read/write bit, and an 11-bit RAM/register address. The control port knows how many data bytes to expect based on the address that is received in the first three bytes. The total number of bytes for a single-location write command can vary from four bytes (for a control register write), to eight bytes (for a program RAM write). Burst mode may be used to fill contiguous register or RAM locations. A burst mode write is done by writing the address and data of the first RAM/register location to be written. Rather than ending the control port transaction (by bringing the CLATCH signal high in the AD1940, after the data word, as would be done in a singleaddress write, the next data word can be written immediately without first writing its specific address. The AD1940 control port autoincrements the address of each write, even across the boundaries of the different RAMs and registers.
CONTROL PORT READ/WRITE DATA FORMATS
The read/write formats of the control port are designed to be byte-oriented. This allows for easy programming of common microcontroller chips. In order to fit into a byte-oriented format, 0s are appended to the data fields before the MSB in order to extend the data word to the next multiple of eight bits. For example, 28-bit words written to the parameter RAM are appended with four leading 0s in order to reach 32 bits (4 bytes); 40-bit words written to the program RAM are not appended with any 0s because it is already a full 5 bytes. These
Table 21. Parameter RAM Read/Write Format (Single Address)
Byte 0 chip_adr [6:0], W/R Byte 1 0000, param_adr[11:8] Byte 2 param_adr[7:0] Byte 3 0000, param[27:24] Bytes 4-6 param [23:0]
Table 22. Parameter RAM Block Read/Write Format (Burst Mode)
Byte 0 chip_adr [6:0], W/R Byte 1 0000, param_adr[11:8] Byte 2 param_adr[7:0] Byte 3 0000, param[27:24] Bytes 4-6 param[23:0] Byte 7 Byte 8 Byte 9 Byte 10 param_adr + 1 Byte 11 Byte 12 Byte 13 Byte 14 param_adr + 2
<--param_adr-->
Table 23. Program RAM Read/Write Format (Single Address)
Byte 0 chip_adr [6:0], W/R Byte 1 0000, prog_adr[11:8] Byte 2 prog_adr[7:0] Bytes 3-7 prog[39:0]
Table 24. Program RAM Block Read/Write Format (Burst Mode)
Byte 0 chip_adr [6:0], W/R Byte 1 0000, prog_adr[11:8] Byte 2 prog_adr[7:0] Byte 3-7 prog[39:0] Byte 8 Byte 9 Byte 10 Byte 11 Byte 12 prog_adr +1 Byte 13 Byte 14 Byte 15 Byte 16 Byte 17 prog_adr +2
<--prog_adr-->
Table 25. Control Register Read/Write Format (Core, Serial Out 0, Serial Out 1)
Byte 0 chip_adr [6:0], W/R Byte1 0000, reg_adr[11:8] Byte 2 reg_adr[7:0] Byte 3 data[15:8] Byte 4 data[7:0]
Table 26. Control Register Read/Write Format (RAM Configuration, Serial Input)
Byte 0 chip_adr [6:0], W/R Byte1 0000, reg_adr[11:8] Byte 2 reg_adr[7:0] Byte 3 data[7:0]
Rev. 0 | Page 22 of 32
AD1940
Table 27. Data Capture Register Write Format
Byte 0 chip_adr [6:0], W/R Byte 1 0000, data_capture_adr[11:8] Byte 2 data_capture_adr[7:0] Byte 3 000, progCount[10:6]1 Byte 4 progCount[5:0]1, regSel[1:0]2
1 2
ProgCount[10:0] = value of program counter where trap occurs (the table of values is generated by the program compiler). RegSel[1:0] selects one of four registers (see Data Capture Registers section).
Table 28. Data Capture (Control Port Readback) Register Read Format
Byte 0 chip_adr [6:0], W/R Byte 1 0000, data_capture_adr[11:8] Byte 2 data_capture_adr[7:0] Bytes 3-5 data[23:0]
Table 29. Safeload Register Data Write Format
Byte 0 chip_adr [6:0], W/R Byte 1 0000, safeload_adr[11:8] Byte 2 safeload_adr[7:0] Byte 3 000000, data[33:32] Bytes 4-7 data[31:0]
Table 30. Safeload Register Address Write Format
Byte 0 chip_adr [6:0], W/R Byte 1 0000, safeload_adr[11:8] Byte 2 safeload_adr[7:0] Byte 3 000000, param_adr[9:8] Byte 4 param_adr[7:0]
Rev. 0 | Page 23 of 32
AD1940 SERIAL DATA INPUT/OUTPUT PORTS
The AD1940's flexible serial data input and output ports can be set to accept or transmit data in 2-channel formats or in an 8- or 16-channel TDM stream. Data is processed in twos complement, MSB-first format. The left channel data field always precedes the right channel data field in the 2-channel streams. In the TDM modes, Slots 0 to 3 (8-channel TDM) or Slots 0 to 7 (16-channel TDM) fall in the first half of the audio frame, and Slots 4 to 7 (or Slots 8 to 15 in 16-channel TDM) are in the second half of the frame. The serial modes are set in the serial output and serial input control registers. The input control register allows control of clock polarity and data input modes. The valid data formats are I2S , left-justified, right-justified (24-, 20-, 18-, or 16-bit), 8-channel, and 16-channel TDM. In all modes except for the right-justified modes, the serial port will accept an arbitrary number of bits up to a limit of 24. Extra bits will not cause an error, but they will be truncated internally. Proper operation of the rightjustified modes requires that there be exactly 64 BCLKs per audio frame. The TDM data is input on SDATA_IN2 and SDATA_IN3 when in 2 x 8-channel TDM mode, and on SDATA_IN2 in 16-channel TDM mode. The LRCLK in TDM mode can be input to the AD1940 as either a 50/50 duty cycle clock or as a bit-wide pulse. The two clock domains on the serial output ports can generate two separate 8-channel TDM streams or one 16-channel TDM Table 31 Serial Output Port Master/Slave Mode Capabilities
fs 48 kHz 96 kHz 192 kHz 2-Channel Modes (I2S, Left-Justified, Right-Justified) Master and slave Master and slave Master and slave 8-Channel TDM Master and slave Master and slave Slave only 16-Channel TDM Master and slave Slave only Slave only
stream. When in 16-channel TDM mode, the data is clocked by LRCLK_OUT0 and BCLK_OUT0. The AD1940 must be in slave mode for 16-channel TDM unless the data is sampled at 48 kHz; the part cannot generate a TDM bit clock that is fast enough to support 96 kHz or 192 kHz. In 8-channel TDM mode, the AD1940 can be a master for 48 kHz and 96 kHz data, but not for 192 kHz data. Table 31 displays the modes in which the serial output port will function. The output control registers give the user control of clock polarities, clock frequencies, clock types, and data format. In all modes except for the right-justified modes (MSB delayed by 8, 12, or 16), the serial port accepts an arbitrary number of bits up to a limit of 24. Extra bits will not cause an error, but will be truncated internally. Proper operation of the right-justified modes requires the LSB to align with the edge of the LRCLK. The default settings of all serial port control registers correspond to 2-channel I2S mode. LRCLK_OUT0 and BCLK_OUT0 are clocks for Serial Output Ports 0 to 7, and LRCLK_OUT1 and BCLK_OUT1 Clock Ports 8 to 15. All registers default to being set as all 0s. All register settings apply to both master and slave modes unless otherwise noted. Table 32 shows the proper configurations for standard audio data formats.
Table 32. Data Format Configurations
Format I2S (Figure 16) Left-Justified (Figure 17) Right-Justified (Figure 18) TDM with Clock (Figure 19) TDM with Pulse (Figure 20) LRCLK Polarity Frame begins on falling edge Frame begins on rising edge Frame begins on rising edge Frame begins on falling edge Frame begins on rising edge LRCLK Type Clock Clock Clock Clock Pulse BCLK Polarity Data changes on falling edge Data changes on falling edge Data changes on falling edge Data changes on falling edge Data changes on falling edge MSB Position Delayed from LRCLK edge by one BCLK Aligned with LRCLK edge Delayed from LRCLK edge by 8, 12, or 16 BCLKs Delayed from start of word clock by one BCLK Delayed from start of word clock by one BCLK
Rev. 0 | Page 24 of 32
AD1940
Table 33. Serial Output Control Register 1 (Channels 0-7) (2644)
Register Bits 15 Function Dither Enable 0 = Diabled 1 = Enabled Internally Link TDM Streams into Single, 16-Channel Stream 0 = Indepenent 1 = Linked LRCLK Polarity 0 = Frame Begins on Falling Edge 1 = Frame Begins on Rising Edge BCLK Polarity 0 = Data Changes on Falling Edge 1 = Data Changes on Rising Edge Master/Slave 0 = Slave 1 = Master BCLK Frequency (Master Mode only) 00 = core_clock/24 01 = core_clock/12 10 = core_clock/6 11 = core_clock/3 Frame Sync Frequency (Master Mode only) 00 = core_clock/1536 01 = core_clock/768 10 = core_clock/384 Frame Sync Type 0 = LRCLK 1 = Pulse Serial Output/TDM Mode Control 0 = 8 Serial Data Outputs 1 = Enable TDM (8- or 16-Channel) on SDATA_OUT0 MSB Position 000 = Delay by 1 001 = Delay by 0 010 = Delay by 8 011 = Delay by 12 100 = Delay by 16 101 Reserved 111 Reserved Output Word Length, Channels 0-7 00 = 24 Bits 01 = 20 Bits 10 = 16 Bits 11 = 16 Bits
Table 34. Serial Output Control Register 2 (Channels 8-15) (2645)
Register Bits 15 Function Dither Enable 0 = Disabled 1 = Enabled Data Capture Serial Out Enable (Uses SDATA_OUT7) 0 = Disable 1 = Enable LRCLK Polarity 0 = Frame Begins on Falling Edge 1 = Frame Begins on Rising Edge BCLK Polarity 0 = Data Changes on Falling Edge 1 = Data Changes on Rising Edge Master/Slave 0 = Slave 1 = Master BCLK Frequency (Master Mode only) 00 = core_clock/24 01 = core_clock/12 10 = core_clock/6 11 = core_clock/3 Frame Sync Frequency (Master Mode only) 00 = core_clock/1536 01 = core_clock/768 10 = core_clock/384 Frame Sync Type 0 = LRCLK 1 = Pulse Serial Output/TDM Mode Control 0 = 8 Serial Data Outputs 1 = Enable TDM on SDATA_OUT4 (8-Channel) or SDATA_OUT0 (16-Channel) MSB Position 000 = Delay by 1 001 = Delay by 0 010 = Delay by 8 011 = Delay by 12 100 = Delay by 16 101 Reserved 111 Reserved Output Word Length, Channels 8-15 00 = 24 Bits 01 = 20 Bits 10 = 16 Bits 11 = 16 Bits
14
14
13
13
12
12
11
11
10:9
10:9
8:7
8:7
6
6
5
5
4:2
4:2
1:0
1:0
Rev. 0 | Page 25 of 32
AD1940
SERIAL OUTPUT CONTROL REGISTERS
Dither Enable (Bit 15) Setting this bit to 1 enables dither on the appropriate channels. Internally Link TDM Streams into Single 16-Channel Stream (Bit 14, Serial Output Control Register 1) When this bit is set to 1, the TDM output stream is output in a single 16-channel stream on SDATA_OUT0. When set to 0, TDM data is output on two independent 8-channel streams on Pins SDATA_OUT0 and SDATA_OUT4. Data Capture Serial Out Enable (Bit 14, Serial Output Control Register 2) When set to 1, SDATA_OUT7 is set as the output of the data capture digital output registers (2640-2641). See the Data Capture Registers section for a full explanation of using this mode. LRCLK Polarity (Bit 13) When set to 0, the left channel data is clocked when LRCLK is low, and the right data clocked when LRCLK is high. When set to 1, this is reversed. BCLK Polarity (Bit 12) This bit controls on which edge of the bit clock the output data is clocked. Data changes on the falling edge of BCLK_OUTx when this bit is set to 0, and on the rising edge when this bit is set at 1. Master/Slave (Bit 11) This bit sets whether the output port is a clock master or slave. The default setting is slave; on power-up, Pins BCLK_OUTx and LRCLK_OUTx are set as inputs until this bit is set to 1, at which time they become clock outputs. BCLK Frequency (Bits 10:9) When the output port is being used as a clock master, these bits set the frequency of the output bit clock, which is divided down from the internal 73.728 MHz core clock. Frame Sync Frequency (Bits 8:7) When the output port is used as a clock master, these bits set the frequency of the output word clock on the LRCLK_OUTx pins, which is divided down from the internal 73.728 MHz core clock. Frame Sync Type (Bit 6) This bit sets the type of signal on the LRCLK_OUTx pins. When set to 0, the signal is a word clock with a 50% duty cycle; when set to 1, the signal is a pulse with a duration of one bit clock at the beginning of the data frame. Serial Output/TDM Mode Control (Bit 5) Setting this bit to 1 changes the output port from multiple serial outputs to a single TDM output stream on the appropriate SDATA_OUTx pin. This bit must be set in both serial output control registers to enable 16-channel TDM on SDATA_OUT0. MSB Position (Bits 4:2) These three bits set the position of the MSB of data with respect to the LRCLK edge. The data output of the AD1940 is always MSB first. Output Word Length (Bits 1:0) These bits set the word length of the output data-word. All bits following the LSB are set to 0. Table 35. Serial Input Control Register (2646)
Register Bits 5 Function 8-/16-channel TDM input 0 = Dual 8-channel TDM 1 = 16-channel TDM input LRCLK polarity 0 = Frame begins on falling edge 1 = Frame begins on rising edge BCLK polarity 0 = Data changes on falling edge 1 = Data changes on rising edge Serial Input Mode 000 = I2S 001 = Left-justified 010 = TDM 011 = Right-justified, 24-bit 100 = Right-justified, 20-bit 101 = Right-justified, 18-bit 110 = Right-justified, 16-bit
4
3
2:0
SERIAL INPUT CONTROL REGISTER
8-/16-Channel TDM Input (Bit 5) Setting this bit to 0 puts the AD1940 into dual 8-channel TDM input mode, with the two streams coming in on SDATA_IN2/TDM_IN1 and SDATA_IN3/TDM_IN0. Channels 0 to 7 will be input on TDM_IN0 and Channels 8 to 15 will come in on TDM_IN1. Setting this bit to 1 puts the part in 16-channel TDM input mode, input on TDM_IN1. LRCLK Polarity (Bit 4) When set to 0, the left channel data on the SDATA_INx pins is clocked when LRCLK_IN is low; and the right input data clocked when LRCLK_IN is high. When set to 1, this is reversed. In TDM mode, when this bit is set to 0, data is clocked in starting with the next appropriate BCLK edge (set in Bit 3 of this register) following a falling edge on the LRCLK_IN pin. When set to 1 and running in TDM mode, the input data is valid on the BCLK edge following a rising edge on the word clock (LRCLK_IN). The serial input port can also operate with a pulse input signal, rather than a clock. In this case, the first edge of the pulse is used by the AD1940 to start the data frame. When this polarity bit is set to 0, a low pulse should be used, and a high pulse should be used when the bit it set to 1.
Rev. 0 | Page 26 of 32
AD1940
BCLK Polarity (Bit 3) This bit controls on which edge of the bit clock the input data changes, and on which edge it is clocked. Data changes on the falling edge of BCLK_IN when this bit is set to 0, and on the rising edge when this bit is set at 1. Serial Input Mode (Bits 2:0) These two bits control the data format that the input port expects to receive. Bits 3 and 4 of this control register will override the settings in Bits 2:0, so all four bits must be changed together for proper operation in some modes. The clock diagrams for these modes are shown in Figure 16, Figure 17, and Figure 18. Note that for left-justified and right-justified modes the LRCLK polarity is high, then low, which is opposite from the default setting of Bit 4. When these bits are set to accept a TDM input, the AD1940's data starts after the edge defined by Bit 4. Figure 19 shows an 8-channel TDM stream with a high-to-low triggered LRCLK and data changing on the falling edge of the BCLK. The AD1940 expects the MSB of each data slot delayed by one BCLK from the beginning of the slot, just like in the stereo I2S format. In 8-channel TDM mode, Channels 0 to 3 will be in the first half of the frame, and Channels 4 to 7 will be in the second half. When in 16-channel TDM mode, the first half-frame will hold Channels 0 to 7, and the second half-frame will have Channels 8 to 15. Figure 20 shows an example of a TDM stream running with a pulse word clock, which would be used to interface to ADI codecs in their auxiliary mode. To work in this mode on either the input or output serial ports, the AD1940 should be set to frame beginning on the rising edge of LRCLK, data changing on the falling edge of BCLK, and MSB position delayed from the start of the word clock by one BCLK. Table 32 explains the clock settings for each of these formats.
LRCLK BCLK SDATA MSB
LEFT CHANNEL
RIGHT CHANNEL
04607-0-023
LSB 1 /FS
MSB
LSB
Figure 16. I S Mode--16 to 24 Bits per Channel
2
SDATA
MSB
LSB
MSB 1 /FS
LSB
Figure 17. Left-Justified Mode--16 to 24 Bits per Channel
LRCLK BCLK SDATA MSB
LEFT CHANNEL LSB
1 /FS
RIGHT CHANNEL
04607-0-025
MSB
LSB
Figure 18. Right-Justified Mode--16 to 24 Bits per Channel
Rev. 0 | Page 27 of 32
04607-0-024
LRCLK BCLK
LEFT CHANNEL
RIGHT CHANNEL
AD1940
LRCLK 256 BCLKs BCLK 32 BCLKs DATA SLOT 1 SLOT 2 SLOT 3 SLOT 4 SLOT 5 SLOT 6 SLOT 7 SLOT 8
LRCLK
04607-0-012
BCLK MSB MSB-1 MSB-2 DATA
Figure 19. 8-Channel TDM Mode. This diagram shows just one of the formats in which the AD1940 can operate in TDM mode. Please refer to the Serial Data Input/Output Ports section for a more complete description of the modes of operation.
LRCLK
BCLK
MSB TDM SDATA
CH 0
MSB TDM
8TH CH
32 BCLKs
Figure 20. TDM Mode with Pulse Word Clock
Rev. 0 | Page 28 of 32
04607-0-022
SLOT 0
SLOT 1
SLOT 2
SLOT 3
SLOT 4
SLOT 5
SLOT 6
SLOT 7
AD1940 INITIALIZATION
POWER-UP SEQUENCE
The AD1940 has a built-in power-up sequence that initializes the contents of all internal RAMs. During this time, the contents of the internal program boot ROM are copied to the internal program RAM memory, and the parameter RAM (all 0s) is filled with values from its associated boot ROM. The default boot ROM program simply copies the serial inputs to the serial outputs with no processing. The data memories are also cleared during this time. The boot sequence, which starts on the rising edge of the RESETB pin, lasts for 8,192 cycles of the signal on the MCLK pin at start-up. Assuming even the slowest possible signal on this pin, a 64 x fS clock, the boot sequence will still complete before the PLL locks to the input clock. Since the boot sequence requires a stable master clock, the user should avoid writing to or reading from the registers until the MCLK input signal has settled and the PLL has locked. The PLL takes approximately 3 ms to lock. Coming out of reset, the clock mode is immediately set by the PLL_CTRL0, PLL_CTRL1, and PLL_CTRL2 pins. Reset is synched to the falling edge of the internal MCLK. The power-up default signal processing flow in the AD1940 simply takes the eight inputs and copies these signals to the 16 digital outputs, as shown in Figure 21.
SDATA_IN0 SDATA_IN1 SDATA_IN2 SDATA_IN3 SDATA_OUT0 SDATA_OUT1 SDATA_OUT2 SDATA_OUT3 SDATA_OUT4 SDATA_OUT5 SDATA_OUT6 SDATA_OUT7
04607-0-004
also run in bypass mode, where the clock present on MCLK is fed directly to the DSP core, although this setting is not recommended for normal operation. Table 36. PLL Modes
MCLK Input 64 x fS 256 x fS 384 x fS 512 x fS Bypass
1
PLL_CTRL2 0 0 X1 1 1
PLL_CTRL1 0 1 X1 0 1
PLL_CTRL0 0 0 1 0 0
X = don't care
The clock mode should not be changed without also resetting the AD1940. If the mode is changed on the fly, a click or pop may result on the outputs. The state of the PLL_CTRLx pins should be changed while RESETB is held low.
VOLTAGE REGULATOR
The AD1940 includes an on-board voltage regulator that allows the chip to be used in systems where a 2.5 V supply is not available, but 3.3 V or 5 V is. The only external components needed for this are a PNP transistor such as an FZT953, a single capacitor, and a single resistor. The recommended design for the voltage regulator is shown in Figure 22. The 10 F and 100 nF capacitors shown in this schematic are recommended for bypassing, but are not necessary for operation. Here, VDD is the main system voltage (3.3 V or 5 V) and should be connected to VSUPPLY. 2.5 V is generated at the transistor's collector, which is connected to the VDD pins, PLL_VDD and VSENSE. The reference voltage on VREF is 1.15 V and is generated by the regulator. A 1 nF capacitor should be connected between this pin and ground. VDRIVE is connected to the base of the PNP transistor. A 1 k resistor should be connected between VDRIVE and VSUPPLY. If the regulator is not used in the design, VSUPPLY, VREF, VDRIVE, and VSENSE can be tied to ground.
DVDD
Figure 21. Default Program Signal Flow
SETTING MASTER CLOCK/PLL MODE
The AD1940's MCLK input feeds a PLL, which generates the 1536 x fS clock to run the DSP core. In normal operation, the input to MCLK must be one of the following; 64 x fS, 256 x fS, 384 x fS, or 512 x fS, where fS is the input sampling rate. The mode is set on PLL_CTRL0, PLL_CTRL1, and PLL_CTRL2, according to Table 36. If the AD1940 is set to receive doublerate signals (by reducing the number of program steps/sample by a factor of 2 using the core control register), then the master clock frequencies must be either 32 x fS, 128 x fS, 192 x fS, or 256 x fS. If the AD1940 is set to receive quad-rate signals (by reducing the number of program steps/sample by a factor of 4 using the core control register), then the master clock frequencies must be one of 16 x fS, 64 x fS, 96 x fS, or 128 x fS. On power-up, a clock signal must be present on MCLK so that the AD1940 can complete its initialization routine. The PLL can
+ 10F
FZT953
+ 10F
100nF
1k
100nF
1nF
VSUPPLY
PLL_VDD
VSENSE
VREF
VDRIVE
VDD
AD1940
Figure 22. Voltage Regulator Design
Rev. 0 | Page 29 of 32
04607-0-009
AD1940 OUTLINE DIMENSIONS
0.75 0.60 0.45 1.60 MAX
48 1
9.00 BSC SQ
37 36
PIN 1
1.45 1.40 1.35
10 6 2
SEATING PLANE
0.20 0.09
7 3.5 0 0.08 MAX COPLANARITY
TOP VIEW
(PINS DOWN)
7.00 BSC SQ
VIEW A
12 13 24 25
0.15 0.05
SEATING PLANE
0.50 BSC
VIEW A
ROTATED 90 CCW COMPLIANT TO JEDEC STANDARDS MS-026BBC
0.27 0.22 0.17
Figure 23. 48-Lead Low-Profile Quad Flat Package [LQFP] Dimensions Shown in Millimeters
ORDERING GUIDE
Model AD1940YST AD1940YSTRL AD1940YSTZ1 AD1940YSTZRL1 Eval-AD1940EB Temperature Range -40C to +105C -40C to +105C -40C to +105C -40C to +105C Package Description 48-Lead LQFP 48-Lead LQFP 48-Lead LQFP 48-Lead LQFP Evaluation Board Package Option ST-48 ST-48 in 13" Reel ST-48 ST-48 in 13" Reel
1
Z= Pb-free part.
Rev. 0 | Page 30 of 32
AD1940 NOTES
Rev. 0 | Page 31 of 32
AD1940 NOTES
(c) 2004 Analog Devices, Inc. All rights reserved. Trademarks and registered trademarks are the property of their respective owners. D04607-0-7/04(0)
Rev. 0 | Page 32 of 32


▲Up To Search▲   

 
Price & Availability of AD1940

All Rights Reserved © IC-ON-LINE 2003 - 2022  

[Add Bookmark] [Contact Us] [Link exchange] [Privacy policy]
Mirror Sites :  [www.datasheet.hk]   [www.maxim4u.com]  [www.ic-on-line.cn] [www.ic-on-line.com] [www.ic-on-line.net] [www.alldatasheet.com.cn] [www.gdcy.com]  [www.gdcy.net]


 . . . . .
  We use cookies to deliver the best possible web experience and assist with our advertising efforts. By continuing to use this site, you consent to the use of cookies. For more information on cookies, please take a look at our Privacy Policy. X